| 
					    This page last changed on Oct 23, 2007 by scytacki.
				     OTViewContextA view has an OTViewContext.  One OTViewContext is shared between sibling views.It provides methods for:
 
	looking up a view serviceadding a view serviceunimplemented: getting a view by objectcreating a child view factory. OTViewFactoryParent views( views that have children views), should create a OTViewFactory instance to create theirchildren views.  A parent view should use the same OTViewFactory instance for all of its children views, this
 way all the children will have the same OTViewContext.
 A parent view uses a OTViewFactory instance by
 
	extending AbstractOTJComponentContainerView and calling one of the createSubViewComponent methodsusing OTViewContext.createChildViewFactory()calling OTJComponentService.getViewFactory() OTJComponentViewContextprovides methods for: 
	finding a view by objectfinding a component by objectThis is used by a lot of the scripts and java code so one view can control another view without
 going through the OTObjects.
 It can be obtained through 2 ways:
implementing OTJComponentViewContextAwarecalling OTJComponentService.getJComponentViewContext() OTJComponentServiceprovides methods to instanciate OTJComponentView.  These views require additional initialization over the basic OTView, so this service takes care of that initialization.
 it can be accessed:
 
	extending AbstractOTJComponentView and calling getJComponentService();getting the OTJComponentServiceFactory which is registered as a view service, and callingcreateOTJComponentService, a view factory has to be passed in.
 OTJComponentViewContextAwareaware interface used to pass the OTJComponentViewContext to a OTJComponentView.  This api is redundant with the method getJComponentViewContext on the OTJComponentService interface.
 A functional difference is that it saves the creation of the OTJComponentServiceImpl,
 just to access the OTJComponentViewContext.
 OTJComponentServiceFactory a factory service provided so OTJComponentService objects can be created by parent views and used to create theirchildren views.  This was created because each parent view needs its own OTJComponentService instance.  If
 AbstractOTJComponentView extended then a parent view doesn't need to worry about this interface.
 Currently this is used in only 7 framework classes.  It is not used by any views besides the top level OTViewer.
 OTViewContainerPanelThis is a JPanel which contains, the JComponent returned by an OTJComponentView.   In many cases it is unnecessary,originally it contained the different accessor methods for things a view needed.  But now views have the view context
 and view factory for that.  The one functionality that provides is the OTViewContainer functionality.  To be a
 proper OTViewContainer an implementer needs to be able to replace the object it is viewing with another one.  In
 most parent view cases this should be possible without maintaining the OTViewContainerPanel, but that needs to be
 verified.
 OTViewChildThis is a way to modify the view entry and scroll bars of a child view.It it can be used in many OTObjects that represent a container view.  Like OTPlacementContainer or OTBorderContainer.
 It has drawbacks.  It cannot be used by an container object that expects a specific child OTObject.
 When the child object is requested from the container object the OTViewChild will be returned instead of the child inside.
 In OTCompoundDoc objects the viewid attribute can be used on the object reference to modify the viewid of a particularobject reference.
 The plan for the future is to support annotations on objects that will allow the view id and scroll bar settings to be specified.Another option is to use css style selectors.
 AbstractOTJComponentContainerViewprovides methods for OTJComponentView objects which are parents of other views.  It provides convenience methodsfor getting components from the children objects.
 AbstractOTJComponentViewprovides basic functionality for OTJComponentViews, 
	reloading views when the view entry changes, this uses the viewContainer, so this is affected by the "updateable" containercode.
creating controller services, so the real object system can be usedgetting child components, these methods don't property setup up the view container so they should be used with cautionstoring the viewContainer. OTViewContainerinteraface which provides methods: 
	changing the current object,getting the parent containergetting the updatable containerreloading the view. An OTViewContainer instance can be accessed: 
	by implementing OTViewContainerAwareextending AbstractOTJComponentView and calling getViewContainer() OTViewContainerAwarea view uses this interface for gaining access to the view container of a view. OTViewMarker interface that all views should implement, typically views implement this indirectly. AbstractOTViewprovides a few useful methods and fields for views.implements OTViewContextAware, provides getViewContext so subclasses can access it.
 creates and caches the viewFactory instance
 OTJComponentViewInterface for views that provide JComponents.  It currently has two methods:getComponent(OTObject otObject);
 viewClosed();
 Classes that implement this method are created by the OTViewFactoryImpl.  This is mainly
 called done by OTJComponentServiceImpl
 OTRequestedViewEntryAwareViews can implement this interface so they know what the request viewEntry was.  The actualview entry can be different because the viewMode was set.   The requested viewEntry can
 be specified by the user explicitly or it could have been determined by matching the OTClass
 to the objectClass of the viewEntry.
 Currently this is only used by OTAuthorEmbedDefaultView
 OTViewEntryThis is an OTClass that is used in a few cases: 
	it is used to register a mapping between a OTClass and viewClass, with the top level OTViewFactory created bythe OTViewBundle
it is passed as an argument to the OTViewFactory so its viewClass is used for an objectit can be extended and new properties added so a particular view can be configured.  Examples of this are:
	
		OTChoiceViewConfigOTImageViewConfig OTViewContextAwareAware interface so views can access the OTViewContext, the Abstract* classes take care of this. OTViewEntryAwareAware interface so views can access the OTViewEntry OTXHTMLViewExtension of OTView that has one method:getXHTMLText(OTObject obj)
 this returns a string of xhtml, which is the "view" of the object.
 |